home *** CD-ROM | disk | FTP | other *** search
/ Developer CD Series 1998 August: Technology Seed / August 1998 ADC Seed CD.toast / Mac OS 8.5b2 / allegro-b2-pseudo-SDK / CIncludes / ATSUnicode.h < prev    next >
Encoding:
C/C++ Source or Header  |  1998-07-17  |  32.2 KB  |  948 lines  |  [TEXT/MPS ]

  1. /*
  2.      File:        ATSUnicode.h
  3.  
  4.      Contains:    Public interfaces for Apple Type Services for Unicode Imaging
  5.  
  6.      Version:    Technology:    Allegro
  7.                  Release:    Allego Seed, Use with 3.1 Universal Interfaces
  8.  
  9.      Copyright:    © 1997-1998 by Apple Computer, Inc., all rights reserved.
  10.  
  11.      Bugs?:        Please include the the file and version information (from above) with
  12.                  the problem description.  Developers belonging to one of the Apple
  13.                  developer programs can submit bug reports to:
  14.  
  15.                      devsupport@apple.com
  16.  
  17. */
  18. #ifndef __ATSUNICODE__
  19. #define __ATSUNICODE__
  20.  
  21. #ifndef __ATSLAYOUTTYPES__
  22. #include <ATSLayoutTypes.h>
  23. #endif
  24. #ifndef __SFNTLAYOUTTYPES__
  25. #include <SFNTLayoutTypes.h>
  26. #endif
  27.  
  28. #ifndef __MACTYPES__
  29. #include <MacTypes.h>
  30. #endif
  31. #ifndef __QUICKDRAW__
  32. #include <Quickdraw.h>
  33. #endif
  34. #ifndef __TEXTCOMMON__
  35. #include <TextCommon.h>
  36. #endif
  37.  
  38.  
  39.  
  40. #if PRAGMA_ONCE
  41. #pragma once
  42. #endif
  43.  
  44. #ifdef __cplusplus
  45. extern "C" {
  46. #endif
  47.  
  48. #if PRAGMA_IMPORT
  49. #pragma import on
  50. #endif
  51.  
  52. #if PRAGMA_STRUCT_ALIGN
  53.     #pragma options align=mac68k
  54. #elif PRAGMA_STRUCT_PACKPUSH
  55.     #pragma pack(push, 2)
  56. #elif PRAGMA_STRUCT_PACK
  57.     #pragma pack(2)
  58. #endif
  59.  
  60. /************/
  61. /*    Types    */
  62. /************/
  63. typedef UniCharArrayPtr *                UniCharArrayHandle;
  64. /*
  65.       UniCharArrayHandle is a handle type to correspond to 
  66.       UniCharArrayPtr, defined in Unicode.h.  It refers 
  67.       to a handle, interpreted as a pointer to an array 
  68.       of UniChar's (UInt16's).
  69. */
  70. typedef UInt32                             UniCharArrayOffset;
  71. /*
  72.       UniCharArrayOffset is used to indicate an offset 
  73.       into an array of UniChar's (UInt16's).  
  74. */
  75. typedef Fixed                             ATSUTextMeasurement;
  76. /*
  77.       ATSUTextMeasurement is exactly what its name implies:  
  78.       a measurement of the size in some direction of text:  
  79.       height, width, ascent, descent, and so on.  
  80. */
  81. typedef UInt32                             ATSUFontID;
  82. /*
  83.       ATSUFontID indicates a particular font family and face.  
  84.       ATSUFontID's are not guaranteed to remain constant across 
  85.       reboots.  Clients should use the font's unique name to 
  86.       get a font token to store in documents which is 
  87.       guaranteed to remain constant across reboots. 
  88. */
  89. typedef UInt16                             ATSUFontFeatureType;
  90. typedef UInt16                             ATSUFontFeatureSelector;
  91. /*
  92.       ATSUFontFeatureType and ATSUFontFeatureSelector are used 
  93.       to identify font features.  
  94. */
  95. typedef FourCharCode                     ATSUFontVariationAxis;
  96. typedef Fixed                             ATSUFontVariationValue;
  97. /*
  98.       ATSUFontVariationAxis and ATSUFontVariationValue are used 
  99.       in connection with font variations.  
  100. */
  101. typedef struct OpaqueATSUTextLayout*     ATSUTextLayout;
  102. /*
  103.       ATSUTextLayout is used to store the attribute information 
  104.       associated with a contiguous block of UniChar's (UInt16's) 
  105.       in memory.  It's typed to be an opaque structure.  
  106. */
  107. typedef struct OpaqueATSUStyle*         ATSUStyle;
  108. /*
  109.       ATSUStyle is used to store a set of individual attributes, 
  110.       font features, and font variations.  It's typed to be 
  111.       an opaque structure.  
  112. */
  113. typedef UInt32                             ATSUAttributeTag;
  114. /*
  115.       ATSUAttributeTag is used to indicate the particular type 
  116.       of attribute under consideration:  font, size, color, 
  117.       and so on.  
  118.       Each style run may have at most one attribute with a 
  119.       given ATSUAttributeTag (i.e., a style run can't have 
  120.       more than one font or size) but may have none.  
  121. */
  122. typedef void *                            ATSUAttributeValuePtr;
  123. /*
  124.       ATSUAttributeValuePtr is used to provide generic access 
  125.       to storage of attribute values, which vary in size.
  126. */
  127.  
  128. struct ATSUAttributeInfo {
  129.     ATSUAttributeTag                 fTag;
  130.     ByteCount                         fValueSize;
  131. };
  132. typedef struct ATSUAttributeInfo        ATSUAttributeInfo;
  133. /*
  134.       ATSUAttributeInfo is used to provide a tag/size pairing.  
  135.       This makes it possible to provide the client information   
  136.       about all the attributes for a given range of text.  This   
  137.       structure is only used to return to the client information   
  138.       about a complete set of attributes.  An array of   
  139.       ATSUAttributeInfos is passed as a parameter so that the   
  140.       client can find out what attributes are set and what their   
  141.       individual sizes are; with that information, they can then   
  142.       query about the values of the attributes they're interested   
  143.       in.  Because arrays of ATSUAttributeInfos are used as parameters   
  144.       to functions, they have to be of a fixed size, hence the   
  145.       value is not included in the structure.  
  146. */
  147.  
  148. struct ATSUCaret {
  149.     Fixed                             fX;
  150.     Fixed                             fY;
  151.     Fixed                             fDeltaX;
  152.     Fixed                             fDeltaY;
  153. };
  154. typedef struct ATSUCaret                ATSUCaret;
  155. /*
  156.       ATSUCaret is to contain complete information regarding a caret:  
  157.       its x- and y-positions (relative to the line's origin), and 
  158.       a delta-x and delta-y indicating the caret's slope.  If the 
  159.       caret is vertical, fDeltaX is 0; if it's horizontal, fDeltaY 
  160.       is 0.  
  161. */
  162.  
  163. typedef int                             ATSUCursorMovementType;
  164. /*
  165.       ATSUCursorMovementType currently can take three values 
  166.       (kATSUByCharacter, kATSUByCluster, and kATSUByWord) 
  167.       and is used to indicate how much to move the cursor.  
  168. */
  169. typedef UInt16                             ATSUVerticalCharacterType;
  170. /*
  171.       ATSUVerticalCharacterType currently can take two values 
  172.       (kATSUStronglyVertical, and kATSUStronglyHorizontal) and 
  173.       is used to indicate whether text is to be laid out as 
  174.       vertical glyphs or horizontal glyphs.  
  175. */
  176. typedef UInt16                             ATSUStyleComparison;
  177. /*
  178.       ATSUStyleComparison is an enumeration with four values 
  179.       (kATUStyleUnequal, ATSUStyleContains, kATSUStyleEquals, 
  180.       and kATSUStyleContainedBy), and is used by ATSUCompareStyles() 
  181.       to indicate if the first style parameter contains as a 
  182.       proper subset, is equal to, or is contained by the second 
  183.       style parameter.
  184. */
  185. /****************************************************/
  186. /*    Gestalt selectors                                */
  187. /*        Move into Gestalt.i when they're stable!!!!    */
  188. /****************************************************/
  189.  
  190. enum {
  191.     gestaltATSUVersion            = FOUR_CHAR_CODE('uisv'),
  192.     gestaltATSUFeatures            = FOUR_CHAR_CODE('uisf')
  193. };
  194.  
  195.  
  196. enum {
  197.     gestaltOriginalATSUVersion    = (1 << 16)
  198. };
  199.  
  200. /****************/
  201. /*    Error codes    */
  202. /****************/
  203.  
  204. enum {
  205.     kATSUInvalidTextLayoutErr    = -8790,                        /*    An attempt was made to use a ATSUTextLayout */
  206.                                                                 /*    which hadn't been initialized or is otherwise */
  207.                                                                 /*    in an invalid state. */
  208.     kATSUInvalidStyleErr        = -8791,                        /*    An attempt was made to use a ATSUStyle which  */
  209.                                                                 /*    hadn't been properly allocated or is otherwise  */
  210.                                                                 /*    in an invalid state.  */
  211.     kATSUInvalidTextRangeErr    = -8792,                        /*    An attempt was made to extract information   */
  212.                                                                 /*    information from or perform an operation on a   */
  213.                                                                 /*    ATSUTextLayout for a range of text not covered   */
  214.                                                                 /*    by the ATSUTextLayout.  */
  215.     kATSUFontsMatched            = -8793,                        /*    This is not an error code but is returned by    */
  216.                                                                 /*    ATSUMatchFontsToText() when changes need to    */
  217.                                                                 /*    be made to the fonts associated with the text.  */
  218.     kATSUFontsNotMatched        = -8794,                        /*    This value is returned by ATSUMatchFontsToText()    */
  219.                                                                 /*    when the text contains Unicode characters which    */
  220.                                                                 /*    cannot be represented by any installed font.  */
  221.     kATSUNoCorrespondingFontErr    = -8795,                        /*    This value is retrned by font ID conversion */
  222.                                                                 /*    routines ATSUFONDtoFontID() and ATSUFontIDtoFOND() */
  223.                                                                 /*    to indicate that the input font ID is valid but */
  224.                                                                 /*    there is no conversion possible.  For example, */
  225.                                                                 /*    data-fork fonts can only be used with ATSUI not */
  226.                                                                 /*    the FontManager, and so converting an ATSUIFontID */
  227.                                                                 /*    for such a font will fail.   */
  228.     kATSUInvalidFontErr            = -8796,                        /*    Used when an attempt was made to use an invalid font ID.*/
  229.     kATSUInvalidAttributeValueErr = -8797,                        /*    Used when an attempt was made to use an attribute with */
  230.                                                                 /*    a bad or undefined value.  */
  231.     kATSUInvalidAttributeSizeErr = -8798,                        /*    Used when an attempt was made to use an attribute with a */
  232.                                                                 /*    bad size.  */
  233.     kATSUInvalidAttributeTagErr    = -8799,                        /*    Used when an attempt was made to use a tag value that*/
  234.                                                                 /*    was not appropriate for the function call it was used.  */
  235.     kATSUInvalidCacheErr        = -8800,                        /*    Used when an attempt was made to read in style data */
  236.                                                                 /*    from an invalid cache.  Either the format of the */
  237.                                                                 /*    cached data doesn't match that used by Apple Type */
  238.                                                                 /*    Services for Unicode™ Imaging, or the cached data */
  239.                                                                 /*    is corrupt.  */
  240.     kATSUNotSetErr                = -8801,                        /*    Used when the client attempts to retrieve an attribute, */
  241.                                                                 /*    font feature, or font variation from a style when it */
  242.                                                                 /*    hadn't been set.  In such a case, the default value will*/
  243.                                                                 /*    be returned for the attribute's value.*/
  244.     kATSUNoStyleRunsAssignedErr    = -8802,                        /*    Used when an attempt was made to measure, highlight or draw*/
  245.                                                                 /*    a ATSUTextLayout object that has no styleRuns associated with it.*/
  246.                                                                 /*    Used when QuickDraw Text encounters an error rendering or measuring*/
  247.     kATSUQuickDrawTextErr        = -8803                            /*    a line of ATSUI text.*/
  248. };
  249.  
  250. /*******************************************************************************/
  251. /*    ATSUI Attribute tags:  Apple reserves values 0 to 65,535 (0 to 0x0000FFFF) */
  252. /*    ATSUI clients may create their own tags with any other value               */
  253. /*******************************************************************************/
  254. /*    Line Control Attribute Tags */
  255.  
  256. enum {
  257.     kATSULineWidthTag            = 1L,                            /*    Type:            ATSUTextMeasurement*/
  258.                                                                 /*    Default value:    0*/
  259.     kATSULineRotationTag        = 2L,                            /*    Type:            Fixed (fixed value in degrees in right-handed coordinate system)*/
  260.                                                                 /*    Default value:    0*/
  261.     kATSULineDirectionTag        = 3L,                            /*    Type:            Boolean; values 0 or 1 (see below for value identities)*/
  262.                                                                 /*    Default value:    kATSULeftToRightBaseDirection*/
  263.     kATSULineJustificationFactorTag = 4L,                        /*    Type:            Fract between 0 and 1*/
  264.                                                                 /*    Default value:    kATSUNoJustification*/
  265.     kATSULineFlushFactorTag        = 5L,                            /*    Type:            Fract between 0 and 1 */
  266.                                                                 /*    Default value:    kATSUStartAlignment*/
  267.     kATSULineBaselineValuesTag    = 6L,                            /*    Type:            BslnBaselineRecord*/
  268.                                                                 /*    Default value:    All zeros.  Calculated from other style attributes (e.g., font and point size)*/
  269.                                                                 /*    Type:            UInt32*/
  270.     kATSULineLayoutOptionsTag    = 7L                            /*    Default value:    kATSUNoLayoutOptions - other options listed in ATSLayoutTypes.h*/
  271. };
  272.  
  273. /*    Run Style Attribute Tags */
  274.  
  275. enum {
  276.                                                                 /* QuickDraw compatibility tags */
  277.     kATSUQDBoldfaceTag            = 256L,                            /*    Type:            Boolean    */
  278.                                                                 /*    Default value:    false*/
  279.     kATSUQDItalicTag            = 257L,                            /*    Type:            Boolean        */
  280.                                                                 /*    Default value:    false*/
  281.     kATSUQDUnderlineTag            = 258L,                            /*    Type:            Boolean    */
  282.                                                                 /*    Default value:    false*/
  283.     kATSUQDCondensedTag            = 259L,                            /*    Type:            Boolean    */
  284.                                                                 /*    Default value:    false*/
  285.     kATSUQDExtendedTag            = 260L,                            /*    Type:            Boolean    */
  286.                                                                 /*    Default value:    false*/
  287.                                                                 /* Common run tags */
  288.     kATSUFontTag                = 261L,                            /*    Type:            ATSUFontID    */
  289.                                                                 /*    Default value:    GetScriptVariable( smSystemScript, smScriptAppFond )*/
  290.     kATSUSizeTag                = 262L,                            /*    Type:            Fixed    */
  291.                                                                 /*    Default value:    GetScriptVariable( smSystemScript, smScriptAppFondSize )    */
  292.     kATSUColorTag                = 263L,                            /*    Type:            RGBColor    */
  293.                                                                 /*    Default value:    (0, 0, 0)*/
  294.     kATSULanguageTag            = 264L,                            /*    Type:            RegionCode    */
  295.                                                                 /*    Default value:    GetScriptVariable( smSystemScript, smScriptLang )*/
  296.                                                                 /*    Less common run tags */
  297.     kATSUVerticalCharacterTag    = 265L,                            /*    Type:            ATSUVerticalCharacterType    */
  298.                                                                 /*    Default value:    kATSUStronglyHorizontal*/
  299.     kATSUImposeWidthTag            = 266L,                            /*    Type:            ATSUTextMeasurement*/
  300.                                                                 /*    Default value:    0*/
  301.     kATSUBeforeWithStreamShiftTag = 267L,                        /*    Type:            Fixed*/
  302.                                                                 /*    Default value:    0*/
  303.     kATSUAfterWithStreamShiftTag = 268L,                        /*    Type:            Fixed*/
  304.                                                                 /*    Default value:    0*/
  305.     kATSUCrossStreamShiftTag    = 269L,                            /*    Type:            Fixed*/
  306.                                                                 /*    Default value:    0*/
  307.     kATSUTrackingTag            = 270L,                            /*    Type:            Fixed*/
  308.                                                                 /*    Default value:    0*/
  309.     kATSUHangingInhibitFactorTag = 271L,                        /*    Type:            Fract between 0 and 1*/
  310.                                                                 /*    Default value:    0*/
  311.     kATSUKerningInhibitFactorTag = 272L,                        /*    Type:            Fract between 0 and 1*/
  312.                                                                 /*    Default value:    0*/
  313.     kATSUDecompositionFactorTag    = 273L,                            /*    Type:            Fixed (-1.0 -> 1.0)*/
  314.                                                                 /*    Default value:    0*/
  315.     kATSUBaselineClassTag        = 274L,                            /*    Type:            BslnBaselineClass  (see SFNTLayoutTypes.h)*/
  316.                                                                 /*    Default value:    kBSLNNoBaselineOverride*/
  317.     kATSUPriorityJustOverrideTag = 275L,                        /*    Type:            ATSJustPriorityWidthDeltaOverrides (see ATSLayoutTypes.h)*/
  318.                                                                 /*    Default value:    all zeros*/
  319.     kATSUNoLigatureSplitTag        = 276L,                            /*    Type:            Boolean*/
  320.                                                                 /*    Default value:    false - ligatures and compound characters have divisable components.*/
  321.     kATSUNoCaretAngleTag        = 277L,                            /*    Type:            Boolean*/
  322.                                                                 /*    Default value:    false - use the character's angularity to determine its boundaries*/
  323.     kATSUSuppressCrossKerningTag = 278L,                        /*    Type:            Boolean*/
  324.                                                                 /*    Default value:    false - do not suppress automatic cross kerning (defined by font)*/
  325.     kATSUNoOpticalAlignmentTag    = 279L,                            /*    Type:            Boolean*/
  326.                                                                 /*    Default value:    false - do not suppress character's automatic optical positional alignment*/
  327.     kATSUForceHangingTag        = 280L,                            /*    Type:            Boolean*/
  328.                                                                 /*    Default value:    false - do not force the character's to hang beyond the line boundaries*/
  329.     kATSUNoSpecialJustificationTag = 281L,                        /*    Type:            Boolean*/
  330.                                                                 /*    Default value:    false - perform post-compensation justification if needed*/
  331.     kATSUMaxATSUITagValue        = 65535L                        /*    This is the maximum Apple ATSUI reserved tag value.  Client defined tags must be larger.*/
  332. };
  333.  
  334. /********************************/
  335. /*    Enumerations and constants    */
  336. /********************************/
  337. /* Cursor movement */
  338.  
  339. enum {
  340.     kATSUByCharacter            = 0,
  341.     kATSUByCluster                = 1,
  342.     kATSUByWord                    = 2
  343. };
  344.  
  345. /* Vertical text types */
  346.  
  347. enum {
  348.     kATSUStronglyHorizontal        = 0,
  349.     kATSUStronglyVertical        = 1
  350. };
  351.  
  352. /* Line direction types (used for kATSULineDirectionTag values) */
  353.  
  354. enum {
  355.     kATSULeftToRightBaseDirection = 0,                            /*    Impose left-to-right or top-to-bottom dominant direction */
  356.     kATSURightToLeftBaseDirection = 1                            /*    Impose right-to-left or bottom-to-top dominant direction */
  357. };
  358.  
  359. /* Style comparison types */
  360.  
  361. enum {
  362.     kATSUStyleUnequal            = 0,
  363.     kATSUStyleContains            = 1,
  364.     kATSUStyleEquals            = 2,
  365.     kATSUStyleContainedBy        = 3
  366. };
  367.  
  368. /* LineFlushFactor convenience defined values */
  369. #define kATSUStartAlignment            ((Fract) 0x00000000L)
  370. #define kATSUEndAlignment            ((Fract) 0x40000000L)
  371. #define kATSUCenterAlignment        ((Fract) 0x20000000L)
  372. /* LineJustificationFactor convenience defined values */
  373. #define kATSUNoJustification        ((Fract) 0x00000000L)
  374. #define kATSUFullJustification        ((Fract) 0x40000000L)
  375. /* Other constants    */
  376.  
  377. enum {
  378.     kATSUInvalidFontID            = 0
  379. };
  380.  
  381.  
  382.  
  383. enum {
  384.     kATSUUseLineControlWidth    = 0x7FFFFFFF
  385. };
  386.  
  387.  
  388.  
  389. enum {
  390.     kATSUUseGrafPortPenLoc        = (long)0xFFFFFFFF,
  391.     kATSUClearAll                = (long)0xFFFFFFFF
  392. };
  393.  
  394.  
  395.  
  396. enum {
  397.     kATSUFromTextBeginning        = (long)0xFFFFFFFF,
  398.     kATSUToTextEnd                = (long)0xFFFFFFFF
  399. };
  400.  
  401.  
  402. /****************/
  403. /*    Functions    */
  404. /****************/
  405.  
  406. /*    Basic style functions    */
  407. EXTERN_API_C( OSStatus )
  408. ATSUCreateStyle                    (ATSUStyle *            oStyle);
  409.  
  410. EXTERN_API_C( OSStatus )
  411. ATSUCreateAndCopyStyle            (ATSUStyle                 iStyle,
  412.                                  ATSUStyle *            oStyle);
  413.  
  414. EXTERN_API_C( OSStatus )
  415. ATSUDisposeStyle                (ATSUStyle                 iStyle);
  416.  
  417. EXTERN_API_C( OSStatus )
  418. ATSUSetStyleRefCon                (ATSUStyle                 iStyle,
  419.                                  UInt32                 iRefCon);
  420.  
  421. EXTERN_API_C( OSStatus )
  422. ATSUGetStyleRefCon                (ATSUStyle                 iStyle,
  423.                                  UInt32 *                oRefCon);
  424.  
  425.  
  426. /*    Style comparison         */
  427. EXTERN_API_C( OSStatus )
  428. ATSUCompareStyles                (ATSUStyle                 iFirstStyle,
  429.                                  ATSUStyle                 iSecondStyle,
  430.                                  ATSUStyleComparison *    oComparison);
  431.  
  432. /*    Attribute manipulations    */
  433. EXTERN_API_C( OSStatus )
  434. ATSUCopyAttributes                (ATSUStyle                 iSourceStyle,
  435.                                  ATSUStyle                 iDestinationStyle);
  436.  
  437. EXTERN_API_C( OSStatus )
  438. ATSUOverwriteAttributes            (ATSUStyle                 iSourceStyle,
  439.                                  ATSUStyle                 iDestinationStyle);
  440.  
  441. EXTERN_API_C( OSStatus )
  442. ATSUUnderwriteAttributes        (ATSUStyle                 iSourceStyle,
  443.                                  ATSUStyle                 iDestinationStyle);
  444.  
  445. /*    Empty styles    */
  446. EXTERN_API_C( OSStatus )
  447. ATSUClearStyle                    (ATSUStyle                 iStyle);
  448.  
  449. EXTERN_API_C( OSStatus )
  450. ATSUStyleIsEmpty                (ATSUStyle                 iStyle,
  451.                                  Boolean *                isClear);
  452.  
  453. /*    Clipboard support    */
  454. EXTERN_API_C( OSStatus )
  455. ATSUCopyToHandle                (ATSUStyle                 iStyle,
  456.                                  Handle                 oStyleHandle);
  457.  
  458. EXTERN_API_C( OSStatus )
  459. ATSUPasteFromHandle                (ATSUStyle                 iStyle,
  460.                                  Handle                 iStyleHandle);
  461.  
  462. /*    Get and set attributes */
  463. EXTERN_API_C( OSStatus )
  464. ATSUCalculateBaselineDeltas        (ATSUStyle                 iStyle,
  465.                                  BslnBaselineClass         iBaselineClass,
  466.                                  BslnBaselineRecord     oBaselineDeltas);
  467.  
  468. EXTERN_API_C( OSStatus )
  469. ATSUSetAttributes                (ATSUStyle                 iStyle,
  470.                                  ItemCount                 iAttributeCount,
  471.                                  ATSUAttributeTag         iTag[],
  472.                                  ByteCount                 iValueSize[],
  473.                                  ATSUAttributeValuePtr     iValue[]);
  474.  
  475. EXTERN_API_C( OSStatus )
  476. ATSUGetAttribute                (ATSUStyle                 iStyle,
  477.                                  ATSUAttributeTag         iTag,
  478.                                  ByteCount                 iExpectedValueSize,
  479.                                  ATSUAttributeValuePtr     oValue,
  480.                                  ByteCount *            oActualValueSize);
  481.  
  482. EXTERN_API_C( OSStatus )
  483. ATSUGetAllAttributes            (ATSUStyle                 iStyle,
  484.                                  ATSUAttributeInfo         oAttributeInfoArray[],
  485.                                  ItemCount                 iTagValuePairArraySize,
  486.                                  ItemCount *            oTagValuePairCount);
  487.  
  488. EXTERN_API_C( OSStatus )
  489. ATSUClearAttributes                (ATSUStyle                 iStyle,
  490.                                  ItemCount                 iTagCount,
  491.                                  ATSUAttributeTag         iTag[]);
  492.  
  493. /*    Font features    */
  494. EXTERN_API_C( OSStatus )
  495. ATSUSetFontFeatures                (ATSUStyle                 iStyle,
  496.                                  ItemCount                 iFeatureCount,
  497.                                  ATSUFontFeatureType     iType[],
  498.                                  ATSUFontFeatureSelector  iSelector[]);
  499.  
  500. EXTERN_API_C( OSStatus )
  501. ATSUGetFontFeature                (ATSUStyle                 iStyle,
  502.                                  ItemCount                 iFeatureIndex,
  503.                                  ATSUFontFeatureType *    oFeatureType,
  504.                                  ATSUFontFeatureSelector * oFeatureSelector);
  505.  
  506. EXTERN_API_C( OSStatus )
  507. ATSUGetAllFontFeatures            (ATSUStyle                 iStyle,
  508.                                  ItemCount                 iMaximumFeatureCount,
  509.                                  ATSUFontFeatureType *    oFeatureType,
  510.                                  ATSUFontFeatureSelector * oFeatureSelector,
  511.                                  ItemCount *            oActualFeatureCount);
  512.  
  513. EXTERN_API_C( OSStatus )
  514. ATSUClearFontFeatures            (ATSUStyle                 iStyle,
  515.                                  ItemCount                 iFeatureCount,
  516.                                  ATSUFontFeatureType     iType[],
  517.                                  ATSUFontFeatureSelector  iSelector[]);
  518.  
  519. /*    Font variations    */
  520. EXTERN_API_C( OSStatus )
  521. ATSUSetVariations                (ATSUStyle                 iStyle,
  522.                                  ItemCount                 iVariationCount,
  523.                                  ATSUFontVariationAxis     iAxis[],
  524.                                  ATSUFontVariationValue  iValue[]);
  525.  
  526. EXTERN_API_C( OSStatus )
  527. ATSUGetFontVariationValue        (ATSUStyle                 iStyle,
  528.                                  ATSUFontVariationAxis     iATSUFontVariationAxis,
  529.                                  ATSUFontVariationValue * oATSUFontVariationValue);
  530.  
  531. EXTERN_API_C( OSStatus )
  532. ATSUGetAllFontVariations        (ATSUStyle                 iStyle,
  533.                                  ItemCount                 iVariationCount,
  534.                                  ATSUFontVariationAxis     oVariationAxes[],
  535.                                  ATSUFontVariationValue  oATSUFontVariationValues[],
  536.                                  ItemCount *            oActualVariationCount);
  537.  
  538. EXTERN_API_C( OSStatus )
  539. ATSUClearFontVariations            (ATSUStyle                 iStyle,
  540.                                  ItemCount                 iAxisCount,
  541.                                  ATSUFontVariationAxis     iAxis[]);
  542.  
  543. /*    Basic text-layout functions    */
  544. EXTERN_API_C( OSStatus )
  545. ATSUCreateTextLayout            (ATSUTextLayout *        oTextLayout);
  546.  
  547. EXTERN_API_C( OSStatus )
  548. ATSUCreateTextLayoutWithTextPtr    (ConstUniCharArrayPtr     iText,
  549.                                  UniCharArrayOffset     iTextOffset,
  550.                                  UniCharCount             iTextLength,
  551.                                  UniCharCount             iTextTotalLength,
  552.                                  ItemCount                 iNumberOfRuns,
  553.                                  UniCharCount             iRunLengths[],
  554.                                  ATSUStyle                 iStyles[],
  555.                                  ATSUTextLayout *        oTextLayout);
  556.  
  557. EXTERN_API_C( OSStatus )
  558. ATSUCreateTextLayoutWithTextHandle (UniCharArrayHandle     iText,
  559.                                  UniCharArrayOffset     iTextOffset,
  560.                                  UniCharCount             iTextLength,
  561.                                  UniCharCount             iTextTotalLength,
  562.                                  ItemCount                 iNumberOfRuns,
  563.                                  UniCharCount             iRunLengths[],
  564.                                  ATSUStyle                 iStyles[],
  565.                                  ATSUTextLayout *        oTextLayout);
  566.  
  567. EXTERN_API_C( OSStatus )
  568. ATSUDisposeTextLayout            (ATSUTextLayout         iTextLayout);
  569.  
  570. EXTERN_API_C( OSStatus )
  571. ATSUSetTextLayoutRefCon            (ATSUTextLayout         iTextLayout,
  572.                                  UInt32                 iRefCon);
  573.  
  574. EXTERN_API_C( OSStatus )
  575. ATSUGetTextLayoutRefCon            (ATSUTextLayout         iTextLayout,
  576.                                  UInt32 *                oRefCon);
  577.  
  578. /*    Text location    */
  579. EXTERN_API_C( OSStatus )
  580. ATSUSetTextPointerLocation        (ATSUTextLayout         iTextLayout,
  581.                                  ConstUniCharArrayPtr     iText,
  582.                                  UniCharArrayOffset     iTextOffset,
  583.                                  UniCharCount             iTextLength,
  584.                                  UniCharCount             iTextTotalLength);
  585.  
  586. EXTERN_API_C( OSStatus )
  587. ATSUSetTextHandleLocation        (ATSUTextLayout         iTextLayout,
  588.                                  UniCharArrayHandle     iText,
  589.                                  UniCharArrayOffset     iTextOffset,
  590.                                  UniCharCount             iTextLength,
  591.                                  UniCharCount             iTextTotalLength);
  592.  
  593. EXTERN_API_C( OSStatus )
  594. ATSUGetTextLocation                (ATSUTextLayout         iTextLayout,
  595.                                  void **                oText,
  596.                                  Boolean *                oTextIsStoredInHandle,
  597.                                  UniCharArrayOffset *    oOffset,
  598.                                  UniCharCount *            oTextLength,
  599.                                  UniCharCount *            oTextTotalLength);
  600.  
  601. /*    Text manipulation    */
  602. EXTERN_API_C( OSStatus )
  603. ATSUTextDeleted                    (ATSUTextLayout         iTextLayout,
  604.                                  UniCharArrayOffset     iDeletedRangeStart,
  605.                                  UniCharCount             iDeletedRangeLength);
  606.  
  607. EXTERN_API_C( OSStatus )
  608. ATSUTextInserted                (ATSUTextLayout         iTextLayout,
  609.                                  UniCharArrayOffset     iInsertionLocation,
  610.                                  UniCharCount             iInsertionLength);
  611.  
  612. EXTERN_API_C( OSStatus )
  613. ATSUTextMoved                    (ATSUTextLayout         iTextLayout,
  614.                                  ConstUniCharArrayPtr     iNewLocation);
  615.  
  616. /*    Layout controls    */
  617. EXTERN_API_C( OSStatus )
  618. ATSUCopyLayoutControls            (ATSUTextLayout         iSource,
  619.                                  ATSUTextLayout         iDest);
  620.  
  621. EXTERN_API_C( OSStatus )
  622. ATSUSetLayoutControls            (ATSUTextLayout         iLayout,
  623.                                  ItemCount                 iAttributeCount,
  624.                                  ATSUAttributeTag         iTag[],
  625.                                  ByteCount                 iValueSize[],
  626.                                  ATSUAttributeValuePtr     iValue[]);
  627.  
  628. EXTERN_API_C( OSStatus )
  629. ATSUGetLayoutControl            (ATSUTextLayout         iLayout,
  630.                                  ATSUAttributeTag         iTag,
  631.                                  ByteCount                 iExpectedValueSize,
  632.                                  ATSUAttributeValuePtr     oValue,
  633.                                  ByteCount *            oActualValueSize);
  634.  
  635. EXTERN_API_C( OSStatus )
  636. ATSUGetAllLayoutControls        (ATSUTextLayout         iLayout,
  637.                                  ATSUAttributeInfo         oAttributeInfoArray[],
  638.                                  ItemCount                 iTagValuePairArraySize,
  639.                                  ItemCount *            oTagValuePairCount);
  640.  
  641. EXTERN_API_C( OSStatus )
  642. ATSUClearLayoutControls            (ATSUTextLayout         iLayout,
  643.                                  ItemCount                 iTagCount,
  644.                                  ATSUAttributeTag         iTag[]);
  645.  
  646.  
  647.  
  648. /*    Style run processing    */
  649. EXTERN_API_C( OSStatus )
  650. ATSUSetRunStyle                    (ATSUTextLayout         iTextLayout,
  651.                                  ATSUStyle                 iStyle,
  652.                                  UniCharArrayOffset     iRunStart,
  653.                                  UniCharCount             iRunLength);
  654.  
  655. EXTERN_API_C( OSStatus )
  656. ATSUGetRunStyle                    (ATSUTextLayout         iTextLayout,
  657.                                  UniCharArrayOffset     iOffset,
  658.                                  ATSUStyle *            oStyle,
  659.                                  UniCharArrayOffset *    oRunStart,
  660.                                  UniCharCount *            oRunLength);
  661.  
  662. EXTERN_API_C( OSStatus )
  663. ATSUGetContinuousAttributes        (ATSUTextLayout         iTextLayout,
  664.                                  UniCharArrayOffset     iOffset,
  665.                                  UniCharCount             iLength,
  666.                                  ATSUStyle                 oStyle);
  667.  
  668. /*    Drawing and measuring    */
  669. EXTERN_API_C( OSStatus )
  670. ATSUDrawText                    (ATSUTextLayout         iTextLayout,
  671.                                  UniCharArrayOffset     iLineOffset,
  672.                                  UniCharCount             iLineLength,
  673.                                  ATSUTextMeasurement     iLocationX,
  674.                                  ATSUTextMeasurement     iLocationY);
  675.  
  676. EXTERN_API_C( OSStatus )
  677. ATSUMeasureText                    (ATSUTextLayout         iTextLayout,
  678.                                  UniCharArrayOffset     iLineStart,
  679.                                  UniCharCount             iLineLength,
  680.                                  ATSUTextMeasurement *    oTextBefore,
  681.                                  ATSUTextMeasurement *    oTextAfter,
  682.                                  ATSUTextMeasurement *    oAscent,
  683.                                  ATSUTextMeasurement *    oDescent);
  684.  
  685. EXTERN_API_C( OSStatus )
  686. ATSUMeasureTextImage            (ATSUTextLayout         iTextLayout,
  687.                                  UniCharArrayOffset     iLineOffset,
  688.                                  UniCharCount             iLineLength,
  689.                                  ATSUTextMeasurement     iLocationX,
  690.                                  ATSUTextMeasurement     iLocationY,
  691.                                  Rect *                    oTextImageRect);
  692.  
  693. /*    Highlighting    */
  694. EXTERN_API_C( OSStatus )
  695. ATSUHighlightText                (ATSUTextLayout         iTextLayout,
  696.                                  ATSUTextMeasurement     iTextBasePointX,
  697.                                  ATSUTextMeasurement     iTextBasePointY,
  698.                                  UniCharArrayOffset     iHighlightStart,
  699.                                  UniCharCount             iHighlightLength);
  700.  
  701. EXTERN_API_C( OSStatus )
  702. ATSUUnhighlightText                (ATSUTextLayout         iTextLayout,
  703.                                  ATSUTextMeasurement     iTextBasePointX,
  704.                                  ATSUTextMeasurement     iTextBasePointY,
  705.                                  UniCharArrayOffset     iHighlightStart,
  706.                                  UniCharCount             iHighlightLength);
  707.  
  708. EXTERN_API_C( OSStatus )
  709. ATSUGetTextHighlight            (ATSUTextLayout         iTextLayout,
  710.                                  ATSUTextMeasurement     iTextBasePointX,
  711.                                  ATSUTextMeasurement     iTextBasePointY,
  712.                                  UniCharArrayOffset     iHighlightStart,
  713.                                  UniCharCount             iHighlightLength,
  714.                                  RgnHandle                 oHighlightRegion);
  715.  
  716. /*    Hit-testing    */
  717. EXTERN_API_C( OSStatus )
  718. ATSUPositionToOffset            (ATSUTextLayout         iTextLayout,
  719.                                  ATSUTextMeasurement     iLocationX,
  720.                                  ATSUTextMeasurement     iLocationY,
  721.                                  UniCharArrayOffset *    ioPrimaryOffset,
  722.                                  Boolean *                oIsLeading,
  723.                                  UniCharArrayOffset *    oSecondaryOffset);
  724.  
  725. EXTERN_API_C( OSStatus )
  726. ATSUOffsetToPosition            (ATSUTextLayout         iTextLayout,
  727.                                  UniCharArrayOffset     iOffset,
  728.                                  Boolean                 iIsLeading,
  729.                                  ATSUCaret *            oMainCaret,
  730.                                  ATSUCaret *            oSecondCaret,
  731.                                  Boolean *                oCaretIsSplit);
  732.  
  733. /*    Cursor movement    */
  734. EXTERN_API_C( OSStatus )
  735. ATSUNextCursorPosition            (ATSUTextLayout         iTextLayout,
  736.                                  UniCharArrayOffset     iOldOffset,
  737.                                  ATSUCursorMovementType  iMovementType,
  738.                                  UniCharArrayOffset *    oNewOffset);
  739.  
  740. EXTERN_API_C( OSStatus )
  741. ATSUPreviousCursorPosition        (ATSUTextLayout         iTextLayout,
  742.                                  UniCharArrayOffset     iOldOffset,
  743.                                  ATSUCursorMovementType  iMovementType,
  744.                                  UniCharArrayOffset *    oNewOffset);
  745.  
  746. EXTERN_API_C( OSStatus )
  747. ATSURightwardCursorPosition        (ATSUTextLayout         iTextLayout,
  748.                                  UniCharArrayOffset     iOldOffset,
  749.                                  ATSUCursorMovementType  iMovementType,
  750.                                  UniCharArrayOffset *    oNewOffset);
  751.  
  752. EXTERN_API_C( OSStatus )
  753. ATSULeftwardCursorPosition        (ATSUTextLayout         iTextLayout,
  754.                                  UniCharArrayOffset     iOldOffset,
  755.                                  ATSUCursorMovementType  iMovementType,
  756.                                  UniCharArrayOffset *    oNewOffset);
  757.  
  758. /*    Line breaking    */
  759. EXTERN_API_C( OSStatus )
  760. ATSUBreakLine                    (ATSUTextLayout         iTextLayout,
  761.                                  UniCharArrayOffset     iLineStart,
  762.                                  ATSUTextMeasurement     iLineWidth,
  763.                                  Boolean                 iUseAsSoftLineBreak,
  764.                                  UniCharArrayOffset *    oLineBreak);
  765.  
  766. EXTERN_API_C( OSStatus )
  767. ATSUSetSoftLineBreak            (ATSUTextLayout         iTextLayout,
  768.                                  UniCharArrayOffset     iLineBreak);
  769.  
  770. EXTERN_API_C( OSStatus )
  771. ATSUGetSoftLineBreaks            (ATSUTextLayout         iTextLayout,
  772.                                  UniCharArrayOffset     iRangeStart,
  773.                                  UniCharCount             iRangeLength,
  774.                                  ItemCount                 iMaximumBreaks,
  775.                                  UniCharArrayOffset     oBreaks[],
  776.                                  ItemCount *            oBreakCount);
  777.  
  778. EXTERN_API_C( OSStatus )
  779. ATSUClearSoftLineBreaks            (ATSUTextLayout         iTextLayout,
  780.                                  UniCharArrayOffset     iRangeStart,
  781.                                  UniCharCount             iRangeLength);
  782.  
  783. /*    Idle processing    */
  784. EXTERN_API_C( OSStatus )
  785. ATSUIdle                        (ATSUTextLayout         iTextLayout);
  786.  
  787. /*    Font matching    */
  788. EXTERN_API_C( OSStatus )
  789. ATSUMatchFontsToText            (ATSUTextLayout         iTextLayout,
  790.                                  UniCharArrayOffset     iTextStart,
  791.                                  UniCharCount             iTextLength,
  792.                                  ATSUFontID *            oFont,
  793.                                  UniCharArrayOffset *    oChangedOffset,
  794.                                  UniCharCount *            oChangedLength);
  795.  
  796. EXTERN_API_C( OSStatus )
  797. ATSUSetTransientFontMatching    (ATSUTextLayout         iTextLayout,
  798.                                  Boolean                 iTransientFontMatching);
  799.  
  800. EXTERN_API_C( OSStatus )
  801. ATSUGetTransientFontMatching    (ATSUTextLayout         iTextLayout,
  802.                                  Boolean *                oTransientFontMatching);
  803.  
  804. /*    Font ID's    */
  805. EXTERN_API_C( OSStatus )
  806. ATSUFontCount                    (ItemCount *            oFontCount);
  807.  
  808. EXTERN_API_C( OSStatus )
  809. ATSUGetFontIDs                    (ATSUFontID             oFontIDs[],
  810.                                  ItemCount                 iArraySize,
  811.                                  ItemCount *            oFontCount);
  812.  
  813. EXTERN_API_C( OSStatus )
  814. ATSUFONDtoFontID                (short                     iFONDNumber,
  815.                                  Style                     iFONDStyle,
  816.                                  ATSUFontID *            oFontID);
  817.  
  818. EXTERN_API_C( OSStatus )
  819. ATSUFontIDtoFOND                (ATSUFontID             iFontID,
  820.                                  short *                oFONDNumber,
  821.                                  Style *                oFONDStyle);
  822.  
  823. /*    Font names    */
  824. EXTERN_API_C( OSStatus )
  825. ATSUCountFontNames                (ATSUFontID             iFontID,
  826.                                  ItemCount *            oFontNameCount);
  827.  
  828. EXTERN_API_C( OSStatus )
  829. ATSUGetIndFontName                (ATSUFontID             iFontID,
  830.                                  ItemCount                 iFontNameIndex,
  831.                                  ByteCount                 iMaximumNameLength,
  832.                                  Ptr                     oName,
  833.                                  ByteCount *            oActualNameLength,
  834.                                  FontNameCode *            oFontNameCode,
  835.                                  FontPlatformCode *        oFontNamePlatform,
  836.                                  FontScriptCode *        oFontNameScript,
  837.                                  FontLanguageCode *        oFontNameLenguage);
  838.  
  839. EXTERN_API_C( OSStatus )
  840. ATSUFindFontName                (ATSUFontID             iFontID,
  841.                                  FontNameCode             iFontNameCode,
  842.                                  FontPlatformCode         iFontNamePlatform,
  843.                                  FontScriptCode         iFontNameScript,
  844.                                  FontLanguageCode         iFontNameLanguage,
  845.                                  ByteCount                 iMaximumNameLength,
  846.                                  Ptr                     oName,
  847.                                  ByteCount *            oActualNameLength,
  848.                                  ItemCount *            oFontNameIndex);
  849.  
  850. EXTERN_API_C( OSStatus )
  851. ATSUFindFontFromName            (Ptr                     iName,
  852.                                  ByteCount                 iNameLength,
  853.                                  FontNameCode             iFontNameCode,
  854.                                  FontPlatformCode         iFontNamePlatform,
  855.                                  FontScriptCode         iFontNameScript,
  856.                                  FontLanguageCode         iFontNameLanguage,
  857.                                  ATSUFontID *            oFontID);
  858.  
  859. /*    Font features    */
  860. EXTERN_API_C( OSStatus )
  861. ATSUCountFontFeatureTypes        (ATSUFontID             iFont,
  862.                                  ItemCount *            oTypeCount);
  863.  
  864. EXTERN_API_C( OSStatus )
  865. ATSUCountFontFeatureSelectors    (ATSUFontID             iFont,
  866.                                  ATSUFontFeatureType     iType,
  867.                                  ItemCount *            oSelectorCount);
  868.  
  869. EXTERN_API_C( OSStatus )
  870. ATSUGetFontFeatureTypes            (ATSUFontID             iFont,
  871.                                  ItemCount                 iMaximumTypes,
  872.                                  ATSUFontFeatureType     oTypes[],
  873.                                  ItemCount *            oActualTypeCount);
  874.  
  875. EXTERN_API_C( OSStatus )
  876. ATSUGetFontFeatureSelectors        (ATSUFontID             iFont,
  877.                                  ATSUFontFeatureType     iType,
  878.                                  ItemCount                 iMaximumSelectors,
  879.                                  ATSUFontFeatureSelector  oSelectors[],
  880.                                  Boolean                 oSelectorIsOnByDefault[],
  881.                                  ItemCount *            oActualSelectorCount,
  882.                                  Boolean *                oIsMutuallyExclusive);
  883.  
  884. EXTERN_API_C( OSStatus )
  885. ATSUGetFontFeatureNameCode        (ATSUFontID             iFont,
  886.                                  ATSUFontFeatureType     iType,
  887.                                  ATSUFontFeatureSelector  iSelector,
  888.                                  FontNameCode *            oNameCode);
  889.  
  890. /*    Font variations    */
  891. EXTERN_API_C( OSStatus )
  892. ATSUCountFontVariations            (ATSUFontID             iFont,
  893.                                  ItemCount *            oVariationCount);
  894.  
  895. EXTERN_API_C( OSStatus )
  896. ATSUGetIndFontVariation            (ATSUFontID             iFont,
  897.                                  ItemCount                 iVariationIndex,
  898.                                  ATSUFontVariationAxis * oATSUFontVariationAxis,
  899.                                  ATSUFontVariationValue * oMinimumValue,
  900.                                  ATSUFontVariationValue * oMaximumValue,
  901.                                  ATSUFontVariationValue * oDefaultValue);
  902.  
  903. EXTERN_API_C( OSStatus )
  904. ATSUGetFontVariationNameCode    (ATSUFontID             iFont,
  905.                                  ATSUFontVariationAxis     iAxis,
  906.                                  FontNameCode *            oNameCode);
  907.  
  908.  
  909. /*    Font Instances    */
  910. EXTERN_API_C( OSStatus )
  911. ATSUCountFontInstances            (ATSUFontID             iFont,
  912.                                  ItemCount *            oInstances);
  913.  
  914. EXTERN_API_C( OSStatus )
  915. ATSUGetFontInstance                (ATSUFontID             iFont,
  916.                                  ItemCount                 iFontInstanceIndex,
  917.                                  ItemCount                 iMaximumVariations,
  918.                                  ATSUFontVariationAxis     oAxes[],
  919.                                  ATSUFontVariationValue  oValues[],
  920.                                  ItemCount *            oActualVariationCount);
  921.  
  922. EXTERN_API_C( OSStatus )
  923. ATSUGetFontInstanceNameCode        (ATSUFontID             iFont,
  924.                                  ItemCount                 iInstanceIndex,
  925.                                  FontNameCode *            oNameCode);
  926.  
  927.  
  928. #if PRAGMA_STRUCT_ALIGN
  929.     #pragma options align=reset
  930. #elif PRAGMA_STRUCT_PACKPUSH
  931.     #pragma pack(pop)
  932. #elif PRAGMA_STRUCT_PACK
  933.     #pragma pack()
  934. #endif
  935.  
  936. #ifdef PRAGMA_IMPORT_OFF
  937. #pragma import off
  938. #elif PRAGMA_IMPORT
  939. #pragma import reset
  940. #endif
  941.  
  942. #ifdef __cplusplus
  943. }
  944. #endif
  945.  
  946. #endif /* __ATSUNICODE__ */
  947.  
  948.